<?php
//------------------------------------------------------------ Contraintes d'accès de la page

	// on vérifie que cette page est appelée à partir de l'index et que l'utilisateur a le droit d'édition
	if(isset($_SESSION) && ($GLOBALS['USER']['level'] >= 4 || $GLOBALS['USER']['admin'])){

		// l'identifiant de la donnée à supprimer est indiqué par un entier
		if(isset($_GET['id']) && numericInt($_GET['id'])){
		
			$nb_communes = valueExists((int)$_GET['id'], "CODECOMMUNE", "commune", $connexion);
			
			if($nb_communes == 1){ // la commune à éditer existe et son identifiant est unique
	
?>
<?php
//------------------------------------------------------------ Valeur des champs avant saisie

	// récupération des informations de la commune
	$query_recuperation_commune = "SELECT NOMCOMMUNE, CODEPOSTAL, CODEPAYS, CODEINSEE, REFERENCEIGN ";
	$query_recuperation_commune .= "FROM commune ";
	$query_recuperation_commune .= "WHERE CODECOMMUNE = ".$_GET['id']." ";
	
	$result_recuperation_commune = mysql_query($query_recuperation_commune, $connexion) or logError("RECUPERATION COMMUNE-".$query_recuperation_commune."-".mysql_error());
	
	$tab_recuperation_commune = mysql_fetch_row($result_recuperation_commune);

	$dv_nom = $tab_recuperation_commune[0]; // valeur du champ nom (edt_nom)
	$dv_cp = $tab_recuperation_commune[1]; // valeur du champ code postal (edt_cp)
	$dv_pays = $tab_recuperation_commune[2]; // valeur du champ pays (edt_pays)
	$dv_ign = $tab_recuperation_commune[3]; // valeur du champ ref. IGN (edt_ign)
	$dv_insee = $tab_recuperation_commune[4]; // valeur du champ code INSEE (edt_insee)
	
	$nomOrigine = $tab_recuperation_commune[0];
	$cpOrigine = $tab_recuperation_commune[1];
	
	mysql_free_result($result_recuperation_commune);
	
	// Valeurs possibles du champ edt_pays
	$query_recuperation_pays = "SELECT CODEPAYS AS id, NOMPAYS AS nom FROM pays ORDER BY nom";
	
	$result_recuperation_pays =  mysql_query($query_recuperation_pays, $connexion) or logError("RECUPERATION PAYS-".$query_recuperation_pays."-".mysql_error());

	$selectPays = array(); // on créé un tableau qui contient la liste des pays ainsi que les informations de chacun
	$nb_pays = 0;
	while($tab_recuperation_pays = mysql_fetch_assoc($result_recuperation_pays)){
		$selectPays[$nb_pays] = $tab_recuperation_pays;
		$nb_pays++;
	}
	
	mysql_free_result($result_recuperation_pays);
	
?>
<?php
//------------------------------------------------------------ Traitements si le formulaire a été envoyé

/********************************* Règles :

	- le nom et le code postal de la commune ne peut pas être vide
	- le couple nom/code postal de la commune ne doit pas être déjà enregistré dans la BDD
	- le pays doit exister dans la BDD

*****************************************/

	$statut = array(); // indique le statut du traitement du formulaire (echec ou succes) - tableau contenant les messages à afficher
	$erreur = false; // indique si une erreur a été rencontrée lors du traitement

	trimTabByKey($_POST, "edt_"); // appel à la fonction trimTabByKey() définie dans fonctions.php
	
	//---------------------------------- Contrôle des données ----------------------------------
	
	if(isset($_POST['form_sent'])){ // si le formulaire est envoyé
	
		// Contrôle des données du nom de la commune
		if(isset($_POST['edt_nom']) && is_string($_POST['edt_nom']) && isset($_POST['edt_cp']) && is_string($_POST['edt_cp'])){
			if(!emptyString($_POST['edt_nom'])){
				if(!isNameFormat($_POST['edt_nom'])){
					$statut[] = "Format du nom de commune incorrect";
					$erreur = true;
				}else{
					$dv_nom = $_POST['edt_nom'];
				}
			}else{
				$statut[] = "Le nom de commune ne peut être effacer";
				$erreur = true;
			}
			if(!emptyString($_POST['edt_cp'])){
				if(!isPostalFormat($_POST['edt_cp'])){
					$statut[] = "Format du code postal incorrect";
					$erreur = true;
				}else{
					$dv_cp = $_POST['edt_cp'];
				}
			}else{
				$statut[] = "Le code postal ne peut être effacé";
				$erreur = true;
			}
			if(!$erreur){
				if(!strcmpCollation($_POST['edt_nom'], $nomOrigine) && !strcmpCollation($_POST['edt_cp'], $cpOrigine)){ // si le nom et le code postal ont été modifiés
					// On vérifie que le couple (Code postal/nom de commune) n'existe pas déjà dans la BDD
					$query_recuperation_nb_communes = "SELECT COUNT(*) FROM commune WHERE NOMCOMMUNE = ".mysqlString($_POST['edt_nom'])." AND CODEPOSTAL = ".mysqlString($_POST['edt_cp']);
					$result_recuperation_nb_communes = mysql_query($query_recuperation_nb_communes, $connexion) or logError("RECUPERATION NB COMMUNES-".$query_recuperation_nb_communes."-".mysql_error());
					$tab_recuperation_nb_communes = mysql_fetch_row($result_recuperation_nb_communes);
					if($tab_recuperation_nb_communes[0] > 0){
						$statut[] = "Cette commune existe déjà";
						$erreur = true;
					}
					mysql_free_result($result_recuperation_nb_communes);
				}
			}
		}else{
			$statut[] = "Aucun nom de commune et/ou code postal indiqué";
			$erreur = true;
		}
		
		// Contrôle des données du pays
		if(isset($_POST['edt_pays']) && is_string($_POST['edt_nom'])){
			if(!numericInt($_POST['edt_pays'])){
				$statut[] = "Format du pays incorrect";
				$erreur = true;
			}else{
				if(valueExists((int)$_POST['edt_pays'], "CODEPAYS", "pays", $connexion) == 1){
					$dv_pays = $_POST['edt_pays'];
				}else{
					$statut[] = "Le pays n'existe pas";
					$erreur = true;
				}
			}
		}else{
			$statut[] = "Aucun pays indiqué";
			$erreur = true;
		}
		
		// Contrôle des données du code INSEE
		if(isset($_POST['edt_insee']) && is_string($_POST['edt_insee'])){ 
			$dv_insee = $_POST['edt_insee'];
		}else{
			$statut[] = "Aucun code INSEE indiqué";
			$erreur = true;
		}
		
		// Contrôle des données de la référence IGN
		if(isset($_POST['edt_ign']) && is_string($_POST['edt_ign'])){ 
			$dv_ign = $_POST['edt_ign'];
		}else{
			$statut[] = "Aucune référence IGN indiquée";
			$erreur = true;
		}
		
		//---------------------------------- Modification de la commune ----------------------------------
	
		if(!$erreur){ // aucune erreur n'a été rencontrée jusqu'ici
			
			$query_modification_commune = "UPDATE commune ";
			$query_modification_commune .= "SET NOMCOMMUNE = ".mysqlString($_POST['edt_nom'])." , CODEPOSTAL = ".mysqlString($_POST['edt_cp'])." , CODEPAYS = ".$_POST['edt_pays']." ";
			if(emptyString($_POST['edt_insee'])){
				$query_modification_commune .= ", CODEINSEE = NULL ";
			}else{
				$query_modification_commune .= ", CODEINSEE = ".mysqlString($_POST['edt_insee'])." ";
			}
			if(emptyString($_POST['edt_ign'])){
				$query_modification_commune .= ", REFERENCEIGN = NULL ";
			}else{
				$query_modification_commune .= ", REFERENCEIGN = ".mysqlString($_POST['edt_ign'])." ";
			}
			$query_modification_commune.= "WHERE CODECOMMUNE = ".$_GET['id']." ";
			
			$result_modification_commune = mysql_query($query_modification_commune, $connexion) or logError("MODIFICATION COMMUNE-".$query_modification_commune."-".mysql_error());
		
			if($result_modification_commune === true){
				$statut[] = "Les informations de la commune ont été modifiées";
				logAction("COMMUNE (id: ".$_GET['id'].") MODIFIEE par ".capitalise($GLOBALS['USER']['prenom'])." ".mb_strtoupper($GLOBALS['USER']['nom'])." (".$GLOBALS['USER']['login'].")");
			}else{
				$statut[] = "Erreur critique lors de la modification de la commune";
				$erreur = true;
			}
		
		}
		
	}
?>
<?php
//------------------------------------------------------------ Affichage du statut si le formulaire a été envoyé

	if(isset($_POST['form_sent'])){ // si le formulaire est envoyé
		
		if($erreur){
			afficherStatut($statut, 3); // appel à la fonction afficherStatut() définie dans fonctions.php
		}else{
			afficherStatut($statut, 1); // appel à la fonction afficherStatut() définie dans fonctions.php
		}
	
	}

?>
<?php
	boutonRetour("index.php?p=gestion/commune_gere"); // // appel à la fonction boutonRetour() définie dans fonctions.php
?>
<form method="post" action="index.php?p=gestion/commune_edite&amp;id=<?php echo $_GET['id']; ?>">
	<table class="formulaire" style="margin-left: auto; margin-right: auto;">
		<tr>
			<th class="titre" colspan="2">Modification des informations d'une commune</th>
		</tr>
		<tr>
			<th class="sous_titre" colspan="2">informations</th>
		</tr>
		<tr>
			<td style="width: 120px" class="etiquette">Nom * :</td>
			<td style="width: 275px" class="champ"><input type="text" name="edt_nom" size="25" value="<?php echo htmlentities($dv_nom, ENT_COMPAT, "UTF-8"); ?>" /></td>
		</tr>
		<tr>
			<td class="etiquette">Code postal * :</td>
			<td class="champ"><input type="text" name="edt_cp" size="25" value="<?php echo htmlentities($dv_cp, ENT_COMPAT, "UTF-8"); ?>" /></td>
		</tr>
		<tr>
			<td class="etiquette">Pays * :</td>
			<td class="champ">
				<select id="edt_pays" name="edt_pays">
					<?php
						if($nb_pays > 0){
							foreach($selectPays as $pays){
								if($pays['id'] == $dv_pays){
									echo "<option value=\"".$pays['id']."\" selected=\"selected\">".htmlentities(capitalise($pays['nom']), ENT_NOQUOTES, "UTF-8")."</option>";
								}else{
									echo "<option value=\"".$pays['id']."\">".htmlentities(capitalise($pays['nom']), ENT_NOQUOTES, "UTF-8")."</option>";
								}
							}
							unset($pays);
						}else{
							echo "<option disabled=\"disabled\">Aucun pays enregistré</option>";
						}
					?>
				</select>
				<input type="text" class="recherche" id="srch_pays" style="vertical-align: top;" value="recherche..." size="10" onfocus="clearField('srch_pays', 'recherche...');" onblur="resetField('srch_pays', 'recherche...');" onkeyup="trierSelect('edt_pays', 'srch_pays');" />
				<br />
				<input type="button" value="Ajouter un pays" onclick="popup('popup.php?p=gestion/pays_ajoute_popup&amp;maj=edt_pays&amp;sel=1', 400, 300);" />
			</td>
		</tr>
		<tr>
			<th class="sous_titre" colspan="2">références</th>
		</tr>
		<tr>
			<td class="etiquette">Code INSEE :</td>
			<td class="champ"><input type="text" name="edt_insee" size="15" value="<?php echo htmlentities($dv_insee, ENT_COMPAT, "UTF-8"); ?>" /></td>
		</tr>
		<tr>
			<td class="etiquette">Ref. IGN :</td>
			<td class="champ"><input type="text" name="edt_ign" size="15" value="<?php echo htmlentities($dv_ign, ENT_COMPAT, "UTF-8"); ?>" /></td>
		</tr>
		<tr>
			<td class="envoi" colspan="2"><input type="submit" value="Modifier" /><input type="hidden" name="form_sent" value="1" /></td>
		</tr>
		<tr>
			<td class="legende" colspan="2">* = champs obligatoires</td>
		</tr>
	</table>
</form>
<?php
//------------------------------------------------------------ Accès refusé à la page

			}else{
				afficherStatut("La commune à éditer n'existe pas", 3); // appel à la fonction afficherStatut() définie dans fonctions.php
			}

		}else{
			afficherStatut("La commune à éditer n'est pas ou mal indiquée", 3); // appel à la fonction afficherStatut() définie dans fonctions.php
		}

	}else{
		if(isset($_SESSION)){
			if(!isset($_SESSION['user_id'])){ // si l'utilisateur n'est pas connecté
				include("pages/connexion.php");
			}else{ // si l'utilisateur est connecté et qu'il n'a pas accès à la page, c'est qu'il n'a pas le droit d'utilisation nécessaire
				include("pages/401.htm");
			}
		}
	}

?>